## Acceso a Hardware

Name

| PINSEL0 to<br>PINSEL9 Values            | Function                                                | Register | Controls             |          |
|-----------------------------------------|---------------------------------------------------------|----------|----------------------|----------|
| 00                                      | Primary (default) function, typically GPIO port         | PINSEL0  | P0[15:0]             |          |
| 01                                      | First alternate function                                | PINSEL1  | P0 [31:16]           |          |
| 10                                      | Second alternate function                               | PINSEL2  | P1 [15:0] (Ethernet) |          |
| 11                                      | Third alternate function                                | PINSEL3  | P1 [31:16]           |          |
| PINMODE_OD0 to<br>PINMODE_OD4<br>Values | Function                                                | PINSEL4  | P2 [15:0]            |          |
| 0                                       | Pin is in the normal (not open drain) mode.             | PINSEL5  | P2 [31:16]           | not used |
| 1                                       | Pin is in the open drain mode.                          | PINSEL6  | P3 [15:0]            | not used |
| PINMODE0 to<br>PINMODE9 Value           | Function                                                | PINSEL7  | P3 [31:16]           |          |
| 00                                      | Pin has an on-chip pull-up resistor enabled.            | PINSEL8  | P4 [15:0]            | not used |
| 01                                      | Repeater mode                                           | PINSEL9  | P4 [31:16]           |          |
| 10                                      | Pin has neither pull-up nor pull-down resistor enabled. |          |                      |          |
| 11                                      | Pin has an on-chip pull-down resistor enabled.          | PINSEL10 | Trace port enable    |          |

|             |                                             |     | Value[1] |             |
|-------------|---------------------------------------------|-----|----------|-------------|
| PINSEL0     | Pin function select register 0.             | R/W | 0        | 0x4002 C000 |
| PINSEL1     | Pin function select register 1.             | R/W | 0        | 0x4002 C004 |
| PINSEL2     | Pin function select register 2.             | R/W | 0        | 0x4002 C008 |
| PINSEL3     | Pin function select register 3.             | R/W | 0        | 0x4002 C00C |
| PINSEL4     | Pin function select register 4              | R/W | 0        | 0x4002 C010 |
| PINSEL7     | Pin function select register 7              | R/W | 0        | 0x4002 C01C |
| PINSEL8     | Pin function select register 8              | R/W | 0        | 0x4002 C020 |
| PINSEL9     | Pin function select register 9              | R/W | 0        | 0x4002 C024 |
| PINSEL10    | Pin function select register 10             | R/W | 0        | 0x4002 C028 |
| PINMODE0    | Pin mode select register 0                  | R/W | 0        | 0x4002 C040 |
| PINMODE1    | Pin mode select register 1                  | R/W | 0        | 0x4002 C044 |
| PINMODE2    | Pin mode select register 2                  | R/W | 0        | 0x4002 C048 |
| PINMODE3    | Pin mode select register 3.                 | R/W | 0        | 0x4002 C04C |
| PINMODE4    | Pin mode select register 4                  | R/W | 0        | 0x4002 C050 |
| PINMODE5    | Pin mode select register 5                  | R/W | 0        | 0x4002 C054 |
| PINMODE6    | Pin mode select register 6                  | R/W | 0        | 0x4002 C058 |
| PINMODE7    | Pin mode select register 7                  | R/W | 0        | 0x4002 C05C |
| PINMODE9    | Pin mode select register 9                  | R/W | 0        | 0x4002 C064 |
| PINMODE_OD0 | Open drain mode control register 0          | R/W | 0        | 0x4002 C068 |
| PINMODE_OD1 | Open drain mode control register 1          | R/W | 0        | 0x4002 C06C |
| PINMODE_OD2 | Open drain mode control register 2          | R/W | 0        | 0x4002 C070 |
| PINMODE_OD3 | Open drain mode control register 3          | R/W | 0        | 0x4002 C074 |
| PINMODE_OD4 | Open drain mode control register 4          | R/W | 0        | 0x4002 C078 |
| I2CPADCFG   | I <sup>2</sup> C Pin Configuration register | R/W | 0        | 0x4002 C07C |

Address

- void SetPINSEL (uint8\_t puerto, uint8\_t pin, uint8\_t modo)
- void SetPINMODE(uint8\_t port, uint8\_t pin, uint8\_t modo)
- void SetDIR(uint32\_t\* puerto, uint8\_t pin, uint8\_t direccion)
- void SetPIN(uint32\_t\* puerto, uint8\_t pin, uint8\_t estado)
- uint8\_t GetPIN(uint8\_t puerto, uint8\_t pin, uint8\_t actividad)

### Mapa de las GPIO del LPC1769



# **Interrupciones**

| Table 51.         | NVIC register map                                                                                                               |        |             |                     |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------|--------|-------------|---------------------|
| Name              | Description                                                                                                                     | Access | Reset value | Address             |
| ISER0 to<br>ISER1 | Interrupt Set-Enable Registers. These 2 registers allow enabling interrupts and reading back the interrupt enables for specific | RW     | 0           | ISER0 - 0xE000 E100 |
| ICER0 to          | peripheral functions.  Interrupt Clear-Enable Registers. These 2 registers allow disabling                                      | RW     | 0           | ICER0 - 0xE000 E180 |
| ICER1             | interrupts and reading back the interrupt enables for specific peripheral functions.                                            |        |             | ICER1 - 0xE000 E184 |
| ISPR0 to          | Interrupt Set-Pending Registers. These 2 registers allow changing the interrupt state to pending and reading back the interrupt | RW     | 0           | ISPR0 - 0xE000 E200 |
| ISFKI             | pending state for specific peripheral functions.                                                                                |        |             | ISPR1 - 0xE000 E204 |
| ICPR0 to          | Interrupt Clear-Pending Registers. These 2 registers allow                                                                      | RW     | 0           | ICPR0 - 0xE000 E280 |
| ICPR1             | changing the interrupt state to not pending and reading back the interrupt pending state for specific peripheral functions.     |        |             | ICPR1 - 0xE000 E284 |
| IABR0 to          | Interrupt Active Bit Registers. These 2 registers allow reading the                                                             | RO     | 0           | IABR0 - 0xE000 E300 |
| IABR1             | current interrupt active state for specific peripheral functions.                                                               |        |             | IABR1 - 0xE000 E304 |

| Interrupción<br>EXTERNA | Puerto |
|-------------------------|--------|
| EINT0                   | P210   |
| EINT1                   | P211   |
| EINT2                   | P212   |
| EINT3                   | P213   |

|      | void | ResetISR(void);                     |
|------|------|-------------------------------------|
| WEAK | void | NMI_Handler(void);                  |
| WEAK | void | <pre>HardFault_Handler(void);</pre> |
| WEAK | void | MemManage Handler(void);            |
| WEAK | void | BusFault_Handler(void);             |
| WEAK | void | UsageFault_Handler(void);           |
| WEAK | void | SVCall_Handler(void);               |
| WEAK | void | DebugMon_Handler(void);             |
| WEAK | void | PendSV_Handler(void);               |
| WEAK | void | SysTick_Handler(void);              |
| WEAK | void | <pre>IntDefaultHandler(void);</pre> |
|      |      |                                     |



# **Systick**



| Table 438. Syst | COUNTFLAG CLKSOURCE TICKINT EN           |        |                |             |
|-----------------|------------------------------------------|--------|----------------|-------------|
| Name            | Description                              | Access | Reset value[1] | Address     |
| STCTRL          | System Timer Control and status register | R/W    | 0x4            | 0xE000 E010 |
| STRELOAD        | System Timer Reload value register       | R/W    | 0              | 0xE000 E014 |
| STCURR          | System Timer Current value register      | R/W    | 0              | 0xE000 E018 |

**STCTRL** 

R/W

0x000F 423F

0xE000 E01C

Clock por defecto: Interno (CCLK)

Si se elige clock externo: STCLK (P3.26) => Seleccionar al pin STCLK en el registro pinMode

**STCALIB** 

STRELOAD = (STCALIB / N) - 1 Si N=1 → tick cada 10ms. (si clock=100Mhz)

System Timer Calibration value register

## **Timers**



- 2 canales de captura, que sacan una foto del timer ante una transición de una entrada. Puede generar, en forma opcional, una interrupción.
- Cuatro registros de match de 32-bit que permiten:
- Operación contínua con generación opcional de interrupción on match.
- Frena timer on match con interrupción opcional.
- Reset timer on match interrupción opcional.
- Hasta cuatro salidas externas correspondientes a los registros de match con las siguientes capacidades:
  - Set low on match.
  - Set high on match.
  - Toggle on match.
  - No hace nada on match.

| Generic<br>Name | Description                                                                                                                                          | Access |   | TIMERn Register/<br>Name & Address                                                       |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|------------------------------------------------------------------------------------------|
| IR              | Interrupt Register. The IR can be written to clear interrupts. The IR can be read to identify which of eight possible interrupt sources are pending. | R/W    | 0 | TOIR - 0x4000 4000<br>T1IR - 0x4000 8000<br>T2IR - 0x4009 0000<br>T3IR - 0x4009 4000     |
| TCR             | Timer Control Register. The TCR is used to control the Timer Counter functions. The Timer Counter can be disabled or reset through the TCR.          | RW     | 0 | T0TCR - 0x4000 4004<br>T1TCR - 0x4000 8004<br>T2TCR - 0x4009 0004<br>T3TCR - 0x4009 4004 |
| TC              | Timer Counter. The 32-bit TC is incremented every PR+1 cycles of PCLK. The TC is controlled through the TCR                                          | R/W    | 0 | TOTC - 0x4000 4008<br>T1TC - 0x4000 8008<br>T2TC - 0x4009 0008<br>T3TC - 0x4009 4008     |
| MCR             | Match Control Register. The MCR is used to control if an interrupt is<br>generated and if the TC is reset when a Match occurs.                       | R/W    | 0 | T0MCR - 0x4000 4014<br>T1MCR - 0x4000 8014<br>T2MCR - 0x4009 0014<br>T3MCR - 0x4009 4014 |

| Generic<br>Name | Description                                                                                                                                                                                  | Access | Reset<br>Value[1] | TIMERn Register/<br>Name & Address                                                       |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------|------------------------------------------------------------------------------------------|
| MR0             | Match Register 0. MR0 can be enabled through the MCR to reset the TC, stop both the TC and PC, and/or generate an interrupt every time MR0 matches the TC.                                   | R/W    | 0                 | T0MR0 - 0x4000 4018<br>T1MR0 - 0x4000 8018<br>T2MR0 - 0x4009 0018<br>T3MR0 - 0x4009 4018 |
| MR1             | Match Register 1. See MR0 description.                                                                                                                                                       | R/W    | 0                 | T0MR1 - 0x4000 401C<br>T1MR1 - 0x4000 801C<br>T2MR1 - 0x4009 001C<br>T3MR1 - 0x4009 401C |
| MR2             | Match Register 2. See MR0 description.                                                                                                                                                       | R/W    | 0                 | T0MR2 - 0x4000 4020<br>T1MR2 - 0x4000 8020<br>T2MR2 - 0x4009 0020<br>T3MR2 - 0x4009 4020 |
| MR3             | Match Register 3. See MR0 description.                                                                                                                                                       | R/W    | 0                 | T0MR3 - 0x4000 4024<br>T1MR3 - 0x4000 8024<br>T2MR3 - 0x4009 0024<br>T3MR3 - 0x4009 4024 |
| CCR             | Capture Control Register. The CCR controls which edges of the capture inputs are used to load the Capture Registers and whether or not an interrupt is generated when a capture takes place. | R/W    | 0                 | T0CCR - 0x4000 4028<br>T1CCR - 0x4000 8028<br>T2CCR - 0x4009 0028<br>T3CCR - 0x4009 4028 |

| Bit  | Symbol         | Description                                                                                                                                                                  | Reset<br>Value |
|------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 0    | Counter Enable | When one, the Timer Counter and Prescale Counter are enabled for counting. When 1, the counters are disabled.                                                                | 0              |
| 1    | Counter Reset  | When one, the Timer Counter and the Prescale Counter are synchronously reset on the next positive edge of PCLK. The counter are pain reset until TCR[1] is returned to zero. | 0              |
| 31:2 | •              | Reserved, user software should not write ones to reserved bits. The value read from a reserved bit is not defined.                                                           | NA             |

| Bit  | Symbol        | Description                                 | Reset<br>Value |
|------|---------------|---------------------------------------------|----------------|
| 0    | MR0 Interrupt | Interrupt flag for match channel 0.         | 0              |
| 1    | MR1 Interrupt | Interrupt flag for match channel 1.         | 0              |
| 2    | MR2 Interrupt | Interrupt flag for match channel 2.         | <b>Q</b> 0     |
| 3    | MR3 Interrupt | Interrupt flag for match channel 3.         | 0              |
| 4    | CR0 Interrupt | Interrupt flag for capture channel 0 event. | 0              |
| 5    | CR1 Interrupt | Interrupt flag for capture channel 1 event. | 0              |
| 31:6 | -             | Reserved                                    | -              |

| Bit | Symbol | Value | Description                                                                                   | Reset<br>Value |
|-----|--------|-------|-----------------------------------------------------------------------------------------------|----------------|
| 0   | MR0I   | 1     | Interrupt on MR0: an interrupt is generated when MR0 matches the value in the TC.             | 0              |
|     |        | 0     | This interrupt is disabled                                                                    |                |
| 1   | MR0R   | 1     | Reset on MR0: the TC will be reset if MR0 matches it.                                         | 0              |
|     |        | 0     | Feature disabled.                                                                             |                |
| 2   | MR0S   | 1     | Stop on MR0: the TC and PC will be stopped and TCR[0] will be set to 0 if MR0 matches the TC. | 0              |
|     |        | 0     | Feature disabled.                                                                             | _              |
| 3   | MR1I   | 1     | Interrupt on MR1: an interrupt is generated when MR1 matches the value in the TC.             | 0              |
|     |        | 0     | This interrupt is disabled                                                                    |                |
| 4   | MR1R   | 1     | Reset on MR1: the TC will be reset if MR1 matches it.                                         | 0              |
|     |        | 0     | Feature disabled.                                                                             |                |
| 5   | 5 MR1S | 1     | Stop on MR1: the TC and PC will be stopped and TCR[0] will be set to 0 if MR1 matches the TC. | 0              |
|     |        | 0     | Feature disabled.                                                                             |                |

| Table 4 | <ol><li>Peripheral Clo<br/>description</li></ol> | ock Selection register 0 (PCLKSEL0 - address 0x40 | 00F C1A8) bit |
|---------|--------------------------------------------------|---------------------------------------------------|---------------|
| Bit     | Symbol                                           | Description                                       | Rese<br>value |
| 1:0     | PCLK_WDT                                         | Peripheral clock selection for WDT.               | 00            |
| 3:2     | PCLK_TIMER0                                      | Peripheral clock selection for TIMER0.            | 00            |
| 5:4     | PCLK_TIMER1                                      | Peripheral clock selection for TIMER1.            | 00            |
| 7:6     | PCLK_UART0                                       | Peripheral clock selection for UART0.             | 00            |
| 9:8     | PCLK_UART1                                       | Peripheral clock selection for UART1.             | 00            |
| 11:10   | T-                                               | Reserved.                                         | NA NA         |
| 13:12   | PCLK_PWM1                                        | Peripheral clock selection for PWM1.              | 00            |
| 15:14   | PCLK_I2C0                                        | Peripheral clock selection for I <sup>2</sup> C0. | 00            |
| 17:16   | PCLK_SPI                                         | Peripheral clock selection for SPI.               | 00            |
| 19:18   |                                                  | Reserved.                                         | NA            |
| 21:20   | PCLK_SSP1                                        | Peripheral clock selection for SSP1.              | 00            |
| 23:22   | PCLK_DAC                                         | Peripheral clock selection for DAC.               | 00            |
| 25:24   | PCLK ADC                                         | Peripheral clock selection for ADC.               | 00            |

| Table | 46. Power<br>descrij | Control for Peripherals register (PCONP - address 0x400F C0C4) bi ption                                    | it             |
|-------|----------------------|------------------------------------------------------------------------------------------------------------|----------------|
| Bit   | Symbol               | Description                                                                                                | Reset<br>value |
| 0     | _                    | Reserved.                                                                                                  | NA             |
| 1     | PCTIM0               | Timer/Counter 0 power/clock control bit.                                                                   | 1              |
| 2     | PCTIM1               | Timer/Counter 1 power/clock control bit.                                                                   | 1              |
| 3     | PCUART0              | UART0 power/clock control bit.                                                                             | 1              |
| 4     | PCUART1              | UART1 power/clock control bit.                                                                             | 1              |
| 5     | _                    | Reserved.                                                                                                  | NA             |
| 6     | PCPWM1               | PWM1 power/clock control bit.                                                                              | 1              |
| 7     | PCI2C0               | The I <sup>2</sup> C0 interface power/clock control bit.                                                   | 1              |
| 8     | PCSPI                | The SPI interface power/clock control bit.                                                                 | 1              |
| 9     | PCRTC                | The RTC power/clock control bit.                                                                           | 1              |
| 10    | PCSSP1               | The SSP 1 interface power/clock control bit.                                                               | 1              |
| 11    | -                    | Reserved.                                                                                                  | NA             |
| 12    | PCADC                | A/D converter (ADC) power/clock control bit.                                                               | 0              |
|       |                      | <b>Note:</b> Clear the PDN bit in the AD0CR before clearing this bit, and set this bit before setting PDN. |                |
| 13    | PCCAN1               | CAN Controller 1 power/clock control bit.                                                                  | 0              |
| 14    | PCCAN2               | CAN Controller 2 power/clock control bit.                                                                  | 0              |
| 15    | PCGPIO               | Power/clock control bit for IOCON, GPIO, and GPIO interrupts.                                              | 1              |
| 16    | PCRIT                | Repetitive Interrupt Timer power/clock control bit.                                                        | 0              |

Table 46. Power Control for Peripherals register (PCONP - address 0x400F C0C4) bit description

|     | descri  |                                                          |                |
|-----|---------|----------------------------------------------------------|----------------|
| Bit | Symbol  | Description                                              | Reset<br>value |
| 17  | PCMCPWM | Motor Control PWM                                        | 0              |
| 18  | PCQEI   | Quadrature Encoder Interface power/clock control bit.    | 0              |
| 19  | PCI2C1  | The I <sup>2</sup> C1 interface power/clock control bit. | 1              |
| 20  | -       | Reserved.                                                | NA             |
| 21  | PCSSP0  | The SSP0 interface power/clock control bit.              | 1              |
| 22  | PCTIM2  | Timer 2 power/clock control bit.                         | 0              |
| 23  | PCTIM3  | Timer 3 power/clock control bit.                         | 0              |
| 24  | PCUART2 | UART 2 power/clock control bit.                          | 0              |
| 25  | PCUART3 | UART 3 power/clock control bit.                          | 0              |
| 26  | PCI2C2  | I <sup>2</sup> C interface 2 power/clock control bit.    | 1              |
| 27  | PCI2S   | I2S interface power/clock control bit.                   | 0              |
| 28  | -       | Reserved.                                                | NA             |
| 29  | PCGPDMA | GPDMA function power/clock control bit.                  | 0              |
| 30  | PCENET  | Ethernet block power/clock control bit.                  | 0              |
| 31  | PCUSB   | USB interface power/clock control bit.                   | 0              |

### **Puerto Serie**

$$UART1_{baudrate} = \frac{PCLK}{16 \times (256 \times U1DLM + U1DLL) \times \left(1 + \frac{DivAddVal}{MulVal}\right)}$$

#define DIR\_UART0 ((volatile uint32\_t \*) 0x4000C000UL)
#define DIR\_UART1 ((volatile uint32\_t \*) 0x40010000UL)

